/*----------------------------
ALLGEMEIN
----------------------------*/
body, div, blockquote, pre, code, ol, ul, li, dl, dt, dd, figure, table, th, td, form, fieldset, legend, input, textarea {
  margin: 0;
  padding: 0; }

.fixed {
  position: fixed !important; }

.hidden {
  visibility: hidden;
  width: 0px;
  height: 0px; }

#anchor-top {
  left: 0;
  top: 0;
  position: absolute; }

.underline {
  border-bottom: 1px dotted #F39200;
  padding-bottom: 1.25rem; }

.round-image img {
  border-radius: 50%; }

figure img {
  display: block; }

.desktop-view {
  display: block; }

body {
  width: 100%;
  background-color: #C3C3C3; }

:focus {
  outline: none; }

.ce_text ul:not(.links-ul), .ce_text ol, .profil-angebot ul {
  margin: 16px; }

#container {
  padding-bottom: 50px; }

#main {
  overflow: hidden; }

fieldset, img, iframe {
  border: 0; }

label {
  font-size: 0.75em; }

input, textarea {
  background-color: #fff;
  border: 1px solid #ccc;
  padding: 3px;
  transition: all 0.5s ease; }
  input:hover, textarea:hover {
    background-color: #eee; }
  input:focus, textarea:focus {
    background-color: #eee;
    border: 1px solid #000; }

.button, button {
  margin: 0;
  padding: 5px 10px;
  text-align: center;
  font-size: 0.8em !important;
  display: inline-block;
  background-color: #fff;
  border: 1px solid #707070;
  height: 100%;
  cursor: pointer;
  transition: all 0.25s ease;
  color: #707070;
  font-weight: 400; }
  .button a, button a {
    color: #707070;
    font-weight: 400;
    text-decoration: none;
    transition: all 0.25s ease; }
  .button:hover, button:hover {
    background-color: #707070;
    color: #fff !important; }
    .button:hover a, button:hover a {
      color: #fff; }

.mobile-view {
  display: none; }

#wrapper {
  display: flex;
  flex-direction: column;
  max-width: 1440px;
  margin: 0 auto;
  background-color: #fff; }

#scrollup {
  bottom: 25px;
  right: 25px;
  position: fixed;
  opacity: .25;
  transition: opacity .5s; }
  #scrollup:hover {
    opacity: .75; }

.bildnachweis {
  position: absolute;
  bottom: 5px;
  right: 10px;
  font-size: 10px;
  opacity: .5;
  color: #707070; }
  .bildnachweis.white {
    color: #fff; }

.note {
  font-size: 0.75em;
  opacity: 0.75; }

.icon--link::before {
  width: 16px;
  height: 16px;
  float: left;
  display: inline-block;
  padding-top: 2px;
  margin-right: 5px;
  background-image: url(../images/icon-link_fff.svg);
  background-position: center center;
  background-repeat: no-repeat;
  content: ""; }

.icon--link.black::before {
  width: 16px;
  height: 16px;
  float: left;
  display: inline-block;
  padding-top: 2px;
  margin-right: 5px;
  background-image: url(../images/icon-link_000.svg);
  background-position: center center;
  background-repeat: no-repeat;
  content: ""; }

.text-copyright {
  font-size: 0.8em; }

#scrollup-button {
  display: none;
  bottom: 10px;
  right: 10px;
  position: fixed;
  opacity: .25;
  transition: opacity .5s; }
  #scrollup-button:hover {
    opacity: .75; }
  #scrollup-button img {
    width: 50px;
    height: 50px; }

.cookiebar {
  width: 33%;
  min-width: 300px;
  right: 10px;
  bottom: 10px;
  left: auto;
  z-index: 100; }
  .cookiebar .cookiebar__text {
    margin: 0 !important; }
  .cookiebar .cookiebar__button {
    margin-top: 10px; }

.link-container {
  display: flex;
  margin: 0 -5px; }
  .link-container > div {
    margin: 5px; }
  .link-container figcaption {
    position: relative;
    text-align: center;
    background-color: #F39200;
    color: #fff; }
  .link-container a {
    text-decoration: none; }
    .link-container a:hover img {
      transform: scale(1.2); }
    .link-container a:hover figcaption {
      background-color: #c07300; }

.textbox {
  background-color: white; }

.internal-link-button a {
  padding: 5px 10px;
  display: inline-block;
  background-color: #F39200;
  margin: 5px 0 20px;
  box-sizing: border-box;
  text-decoration: none;
  font-size: 1.25em;
  text-transform: uppercase;
  color: #fff;
  float: right; }
  .internal-link-button a:hover {
    background-color: #c07300; }

/***************RESPONSIVE DESIGN***************/
@media all and (max-width: 767px) {
  body {
    line-height: normal; }

  .fixed {
    position: absolute !important; }

  #container {
    margin: 0 10px; }

  .mobile-view {
    display: block; }

  .ce_text {
    margin-right: 10px;
    margin-left: 10px; } }
@media all and (max-width: 479px) {
  .text-2-column {
    column-count: 1; }

  .cookiebar {
    width: 100%;
    right: auto;
    left: 0;
    bottom: 0; } }
/*----------------------------
FONTS
----------------------------*/
/* ubuntu-300 - latin */
@font-face {
  font-family: 'Ubuntu';
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/ubuntu-v14-latin-300.eot");
  /* IE9 Compat Modes */
  src: local("Ubuntu Light"), local("Ubuntu-Light"), url("../fonts/ubuntu-v14-latin-300.eot?#iefix") format("embedded-opentype"), url("../fonts/ubuntu-v14-latin-300.woff2") format("woff2"), url("../fonts/ubuntu-v14-latin-300.woff") format("woff"), url("../fonts/ubuntu-v14-latin-300.ttf") format("truetype"), url("../fonts/ubuntu-v14-latin-300.svg#Ubuntu") format("svg");
  /* Legacy iOS */ }
/* ubuntu-regular - latin */
@font-face {
  font-family: 'Ubuntu';
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/ubuntu-v14-latin-regular.eot");
  /* IE9 Compat Modes */
  src: local("Ubuntu Regular"), local("Ubuntu-Regular"), url("../fonts/ubuntu-v14-latin-regular.eot?#iefix") format("embedded-opentype"), url("../fonts/ubuntu-v14-latin-regular.woff2") format("woff2"), url("../fonts/ubuntu-v14-latin-regular.woff") format("woff"), url("../fonts/ubuntu-v14-latin-regular.ttf") format("truetype"), url("../fonts/ubuntu-v14-latin-regular.svg#Ubuntu") format("svg");
  /* Legacy iOS */ }
/* ubuntu-700 - latin */
@font-face {
  font-family: 'Ubuntu';
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/ubuntu-v14-latin-700.eot");
  /* IE9 Compat Modes */
  src: local("Ubuntu Bold"), local("Ubuntu-Bold"), url("../fonts/ubuntu-v14-latin-700.eot?#iefix") format("embedded-opentype"), url("../fonts/ubuntu-v14-latin-700.woff2") format("woff2"), url("../fonts/ubuntu-v14-latin-700.woff") format("woff"), url("../fonts/ubuntu-v14-latin-700.ttf") format("truetype"), url("../fonts/ubuntu-v14-latin-700.svg#Ubuntu") format("svg");
  /* Legacy iOS */ }
body, button {
  font-family: 'Ubuntu', sans-serif;
  font-size: 16px; }

h1, h2, h3, h4, h5, h6 {
  color: #707070; }

/***************RESPONSIVE DESIGN***************/
/*----------------------------
FLUIDGRID
----------------------------*/
@media (max-width: 767px) {
  .wrapper {
    width: auto; }

  *[class*="grid"] {
    float: none !important;
    display: block !important;
    width: auto !important; }

  *[class*="offset"] {
    margin-left: 10px !important; } }
@media (min-width: 768px) and (max-width: 1439px) {
  .wrapper {
    width: calc(100% - 20px);
    margin: 0 auto;
    overflow: hidden;
    min-height: 1px;
    height: auto; }

  .grid1 {
    width: calc(100% * (1 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset1 {
    margin-left: calc((100% - 10px) * (1 / 12)); }

  .textbox.grid1 {
    width: calc(100% * (1 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset1 {
    margin-left: calc((100% - 10px) * (1 / 12) - 10px); }

  .grid2 {
    width: calc(100% * (2 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset2 {
    margin-left: calc((100% - 10px) * (2 / 12)); }

  .textbox.grid2 {
    width: calc(100% * (2 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset2 {
    margin-left: calc((100% - 10px) * (2 / 12) - 10px); }

  .grid3 {
    width: calc(100% * (3 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset3 {
    margin-left: calc((100% - 10px) * (3 / 12)); }

  .textbox.grid3 {
    width: calc(100% * (3 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset3 {
    margin-left: calc((100% - 10px) * (3 / 12) - 10px); }

  .grid4 {
    width: calc(100% * (4 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset4 {
    margin-left: calc((100% - 10px) * (4 / 12)); }

  .textbox.grid4 {
    width: calc(100% * (4 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset4 {
    margin-left: calc((100% - 10px) * (4 / 12) - 10px); }

  .grid5 {
    width: calc(100% * (5 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset5 {
    margin-left: calc((100% - 10px) * (5 / 12)); }

  .textbox.grid5 {
    width: calc(100% * (5 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset5 {
    margin-left: calc((100% - 10px) * (5 / 12) - 10px); }

  .grid6 {
    width: calc(100% * (6 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset6 {
    margin-left: calc((100% - 10px) * (6 / 12)); }

  .textbox.grid6 {
    width: calc(100% * (6 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset6 {
    margin-left: calc((100% - 10px) * (6 / 12) - 10px); }

  .grid7 {
    width: calc(100% * (7 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset7 {
    margin-left: calc((100% - 10px) * (7 / 12)); }

  .textbox.grid7 {
    width: calc(100% * (7 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset7 {
    margin-left: calc((100% - 10px) * (7 / 12) - 10px); }

  .grid8 {
    width: calc(100% * (8 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset8 {
    margin-left: calc((100% - 10px) * (8 / 12)); }

  .textbox.grid8 {
    width: calc(100% * (8 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset8 {
    margin-left: calc((100% - 10px) * (8 / 12) - 10px); }

  .grid9 {
    width: calc(100% * (9 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset9 {
    margin-left: calc((100% - 10px) * (9 / 12)); }

  .textbox.grid9 {
    width: calc(100% * (9 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset9 {
    margin-left: calc((100% - 10px) * (9 / 12) - 10px); }

  .grid10 {
    width: calc(100% * (10 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset10 {
    margin-left: calc((100% - 10px) * (10 / 12)); }

  .textbox.grid10 {
    width: calc(100% * (10 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset10 {
    margin-left: calc((100% - 10px) * (10 / 12) - 10px); }

  .grid11 {
    width: calc(100% * (11 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset11 {
    margin-left: calc((100% - 10px) * (11 / 12)); }

  .textbox.grid11 {
    width: calc(100% * (11 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset11 {
    margin-left: calc((100% - 10px) * (11 / 12) - 10px); }

  .grid12 {
    width: calc(100% * (12 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset12 {
    margin-left: calc((100% - 10px) * (12 / 12)); }

  .textbox.grid12 {
    width: calc(100% * (12 / 12) - 10px);
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }
  .textbox.offset12 {
    margin-left: calc((100% - 10px) * (12 / 12) - 10px); } }
@media (min-width: 1440px) {
  .wrapper {
    width: calc(1440px - 20px);
    margin: 0 auto;
    overflow: hidden;
    min-height: 1px;
    height: auto; }

  .grid1 {
    width: calc((1440px - 20px) * (1 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset1 {
    margin-left: calc((1440px - 20px) * (1 / 12)); }

  .grid2 {
    width: calc((1440px - 20px) * (2 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset2 {
    margin-left: calc((1440px - 20px) * (2 / 12)); }

  .grid3 {
    width: calc((1440px - 20px) * (3 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset3 {
    margin-left: calc((1440px - 20px) * (3 / 12)); }

  .grid4 {
    width: calc((1440px - 20px) * (4 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset4 {
    margin-left: calc((1440px - 20px) * (4 / 12)); }

  .grid5 {
    width: calc((1440px - 20px) * (5 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset5 {
    margin-left: calc((1440px - 20px) * (5 / 12)); }

  .grid6 {
    width: calc((1440px - 20px) * (6 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset6 {
    margin-left: calc((1440px - 20px) * (6 / 12)); }

  .grid7 {
    width: calc((1440px - 20px) * (7 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset7 {
    margin-left: calc((1440px - 20px) * (7 / 12)); }

  .grid8 {
    width: calc((1440px - 20px) * (8 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset8 {
    margin-left: calc((1440px - 20px) * (8 / 12)); }

  .grid9 {
    width: calc((1440px - 20px) * (9 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset9 {
    margin-left: calc((1440px - 20px) * (9 / 12)); }

  .grid10 {
    width: calc((1440px - 20px) * (10 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset10 {
    margin-left: calc((1440px - 20px) * (10 / 12)); }

  .grid11 {
    width: calc((1440px - 20px) * (11 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset11 {
    margin-left: calc((1440px - 20px) * (11 / 12)); }

  .grid12 {
    width: calc((1440px - 20px) * (12 / 12));
    float: left;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box; }

  .offset12 {
    margin-left: calc((1440px - 20px) * (12 / 12)); } }
/*----------------------------
STARTSEITE
----------------------------*/
h1 {
  text-align: center; }

#produktauswahl .wrapper {
  display: flex;
  justify-content: center;
  flex-wrap: wrap; }
  #produktauswahl .wrapper .button {
    flex: 1;
    max-width: 395px;
    text-decoration: none;
    border: none; }
    #produktauswahl .wrapper .button h2 {
      margin: 3px 0;
      padding: 10px;
      background-color: #707070;
      color: #fff; }
    #produktauswahl .wrapper .button img {
      transform: scale(1.1);
      transition: all 0.25s ease; }
    #produktauswahl .wrapper .button:hover {
      background-color: transparent; }
      #produktauswahl .wrapper .button:hover img {
        transform: scale(1); }
  #produktauswahl .wrapper .subdivContainer {
    flex-basis: 100%;
    display: none; }
    #produktauswahl .wrapper .subdivContainer .subdiv {
      display: flex;
      justify-content: center;
      margin: 10px;
      border: 1px solid #ccc;
      padding: 10px; }

/***************RESPONSIVE DESIGN***************/
@media all and (max-width: 979px) {
  #produktauswahl .wrapper .button {
    max-width: 336px; } }
@media all and (max-width: 767px) {
  #produktauswahl .wrapper {
    flex-direction: column; }
    #produktauswahl .wrapper .button {
      max-width: none; } }
/*----------------------------
Konfigurator
----------------------------*/
.konfigurator input, .konfigurator textarea, .konfigurator select {
  border-color: #F39200;
  margin-bottom: 5px;
  padding: 3px;
  font-size: 1.1em;
  color: #F39200;
  background-color: #eee; }
.konfigurator #main .inside .mod_article:not(#auswahl) {
  padding-bottom: 20px;
  margin: 0 10px 20px 75px;
  border-bottom: 1px dotted #e6e6e6; }

#produktbeschreibung {
  padding: 20px 0;
  margin: 20px 10px;
  border-top: 1px dotted #e6e6e6;
  border-bottom: 1px dotted #e6e6e6; }
  #produktbeschreibung .rsts-skin-default .rsts-prev, #produktbeschreibung .rsts-skin-default .rsts-next, #produktbeschreibung .rsts-skin-default .rsts-video-play, #produktbeschreibung .rsts-skin-default .rsts-video-stop, #produktbeschreibung .rsts-skin-default .rsts-thumbs-prev, #produktbeschreibung .rsts-skin-default .rsts-thumbs-next {
    top: 15px;
    bottom: auto; }
  #produktbeschreibung .rsts-skin-default .rsts-nav {
    top: 12px;
    bottom: auto; }
  #produktbeschreibung .picture {
    width: 50%;
    margin-left: 65px; }
    #produktbeschreibung .picture::after {
      content: url("../images/element_arrowdown.svg"); }
  #produktbeschreibung h2 {
    margin-top: 3px;
    margin-bottom: 0px;
    padding: 10px;
    background-color: #F39200;
    color: #fff;
    text-align: center; }
  #produktbeschreibung img {
    width: 100%; }
  #produktbeschreibung .wrapper {
    display: flex; }
  #produktbeschreibung .detail-list {
    width: calc(50% - 105px);
    margin-left: 30px;
    justify-content: center; }
    #produktbeschreibung .detail-list h3 {
      padding-bottom: 0.5em;
      border-bottom: 1px solid; }
  #produktbeschreibung .ce_list.icon-checkmark {
    list-style: none;
    display: flex;
    align-items: center; }
    #produktbeschreibung .ce_list.icon-checkmark li {
      line-height: 250%; }
    #produktbeschreibung .ce_list.icon-checkmark li::before {
      content: url("../images/icon_checkmark.svg") " ";
      width: 12px;
      display: block;
      float: left;
      margin-right: 1em; }

#abmessungen {
  display: flex;
  width: 50%; }
  #abmessungen form {
    display: flex; }
  #abmessungen .select {
    display: flex;
    flex-direction: column;
    margin: 10px 10px 10px 0;
    width: 50%; }
  #abmessungen::before {
    content: "1.";
    font-size: 3em;
    font-weight: 700;
    margin: 0 15px;
    color: #e6e6e6;
    position: absolute;
    left: 0; }

#optionen {
  display: flex;
  width: 50%; }
  #optionen::before {
    content: "2.";
    font-size: 3em;
    font-weight: 700;
    margin: 0 15px;
    color: #e6e6e6;
    position: absolute;
    left: 0; }
  #optionen .widget {
    margin-top: 10px !important;
    padding-top: 10px;
    font-size: 1.1em; }
    #optionen .widget .is--flex {
      display: flex;
      flex-direction: column; }
      #optionen .widget .is--flex .legend {
        position: relative;
        font-weight: 700;
        padding: 10px;
        color: #fff;
        background-color: #F39200;
        cursor: pointer;
        transition: 0.25s all ease; }
        #optionen .widget .is--flex .legend:hover {
          background-color: #c07300; }
        #optionen .widget .is--flex .legend::after {
          content: url("../images/icon_arrow_down.svg") " ";
          position: absolute;
          top: 0;
          right: 0;
          width: 16px;
          display: block;
          float: right;
          padding: 10px;
          transform: rotate(-90deg);
          transition: 0.25s all ease; }
        #optionen .widget .is--flex .legend.active::after {
          transform: rotate(0deg); }
        #optionen .widget .is--flex .legend:hover::after {
          transform: rotate(0deg); }
        #optionen .widget .is--flex .legend.active:hover::after {
          transform: rotate(180deg); }
      #optionen .widget .is--flex .options {
        display: none;
        flex-direction: column;
        padding: 10px;
        background-color: #eee;
        border: 1px solid #F39200; }
        #optionen .widget .is--flex .options .is--flex {
          flex-direction: row; }
          #optionen .widget .is--flex .options .is--flex > div {
            flex: 1; }
        #optionen .widget .is--flex .options > span {
          margin-bottom: 10px;
          float: left; }
        #optionen .widget .is--flex .options label {
          font-size: 1em; }
    #optionen .widget select {
      width: calc(100% - 10px);
      margin-right: 10px; }
  #optionen .option-image {
    margin: 0 10px 10px 0; }

#auswahl {
  background-color: #707070;
  color: #fff;
  position: absolute;
  overflow: auto;
  max-height: 100%;
  z-index: 100;
  top: 0;
  right: 0;
  width: calc(50% - 20px);
  max-width: calc(50% - 105px);
  padding: 10px;
  box-sizing: border-box;
  margin: 0 !important; }
  #auswahl h2, #auswahl h3 {
    color: #fff;
    margin: 0; }
  #auswahl h3 {
    margin-bottom: 0; }
  #auswahl button:hover {
    border-color: #fff !important; }
  #auswahl table {
    font-size: 0.8em;
    margin-bottom: 20px;
    width: 100%; }
    #auswahl table td {
      padding: 5px;
      text-align: right; }
      #auswahl table td:nth-of-type(1), #auswahl table td:nth-of-type(3) {
        width: 25% !important; }
      #auswahl table td:nth-of-type(2) {
        width: 50% !important; }
    #auswahl table tr:first-child {
      border-bottom: 1px solid #fff; }
    #auswahl table tr:last-child {
      border-top: 1px solid #fff;
      border-bottom: 3px double #fff; }
  #auswahl .ce_form {
    display: none; }
  #auswahl input {
    color: #000; }
  #auswahl textarea {
    border: none;
    width: 100%;
    color: #000; }

/***************RESPONSIVE DESIGN***************/
@media all and (max-width: 767px) {
  .konfigurator #main .inside .mod_article:not(#auswahl) {
    margin-left: 0; }

  #produktbeschreibung {
    margin-left: 0px;
    margin-right: 0px; }
    #produktbeschreibung .wrapper {
      flex-direction: column; }
    #produktbeschreibung .picture {
      width: 100%;
      margin-left: 0; }
    #produktbeschreibung .detail-list {
      margin: 20px 0;
      width: 100%; }

  #abmessungen, #optionen {
    flex-direction: column;
    width: 100%; }
    #abmessungen h2, #optionen h2 {
      margin: 0 0 0 50px;
      font-size: 1.4em; }
    #abmessungen::before, #optionen::before {
      margin: 0; }

  #optionen .widget .is--flex .legend {
    text-align: left;
    margin-bottom: 5px; }

  #auswahl {
    position: relative;
    width: 100%;
    max-width: 100%; } }
/*----------------------------
FORMS
----------------------------*/
.ce_form .widget {
  margin-top: 5px; }
.ce_form .formbody > fieldset {
  padding: 10px;
  border: 1px dotted #e6e6e6;
  margin-bottom: 10px; }
  .ce_form .formbody > fieldset > legend {
    padding: 0 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #e6e6e6; }
.ce_form .ansprechpartner .widget-select {
  display: flex;
  flex-direction: column;
  width: 100px; }
.ce_form .ausbildungsstellen .widget, .ce_form .praktikantenstellen .widget {
  margin: 15px 0; }
  .ce_form .ausbildungsstellen .widget.explanation, .ce_form .praktikantenstellen .widget.explanation {
    margin-top: 30px; }
  .ce_form .ausbildungsstellen .widget legend, .ce_form .praktikantenstellen .widget legend {
    margin: 5px 0;
    max-width: 75%; }
  .ce_form .ausbildungsstellen .widget .is--flex, .ce_form .praktikantenstellen .widget .is--flex {
    display: flex;
    justify-content: space-between; }
.ce_form .ausbildungsstellen label, .ce_form .praktikantenstellen label {
  font-size: 1em; }
.ce_form .ausbildungsstellen .widget-text, .ce_form .praktikantenstellen .widget-text {
  display: flex;
  justify-content: space-between; }
  .ce_form .ausbildungsstellen .widget-text label, .ce_form .praktikantenstellen .widget-text label {
    margin: 5px 0;
    flex-basis: 75%; }
  .ce_form .ausbildungsstellen .widget-text input, .ce_form .praktikantenstellen .widget-text input {
    flex-basis: 50px;
    text-align: center; }
.ce_form .ausbildungsstellen .widget-text {
  flex-direction: column; }
  .ce_form .ausbildungsstellen .widget-text input {
    flex-basis: auto; }

.form-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.75);
  z-index: 1000;
  display: none;
  justify-content: center;
  align-items: center; }
  .form-overlay .form-container {
    width: 80%;
    margin: 10% auto 0;
    max-width: 980px;
    padding: 20px;
    position: relative;
    background-color: #fff;
    box-sizing: border-box; }
    .form-overlay .form-container button.close {
      background: transparent;
      border: none;
      cursor: pointer;
      position: absolute;
      right: 10px;
      top: 10px; }
      .form-overlay .form-container button.close img {
        width: 12px; }
    .form-overlay .form-container .formbody {
      display: flex;
      flex-wrap: wrap; }
      .form-overlay .form-container .formbody > fieldset {
        flex: 1;
        padding: 20px 0; }
        .form-overlay .form-container .formbody > fieldset > legend {
          text-transform: uppercase;
          color: #ccc; }
      .form-overlay .form-container .formbody > .widget {
        flex: 100%; }
    .form-overlay .form-container .widget {
      display: flex;
      flex-direction: column;
      padding-right: 10px;
      flex: 1;
      margin-bottom: 10px; }
    .form-overlay .form-container label {
      margin: 5px 0; }
    .form-overlay .form-container input, .form-overlay .form-container textarea {
      background-color: #fff;
      border-bottom: 1px solid #eee;
      border-left: none;
      border-right: none;
      border-top: none;
      padding: 3px;
      transition: all 0.5s ease; }
      .form-overlay .form-container input:hover, .form-overlay .form-container input:focus, .form-overlay .form-container textarea:hover, .form-overlay .form-container textarea:focus {
        background-color: #eee; }
    .form-overlay .form-container .checkbox_container {
      display: flex; }

input[type=text], input[type=number], input[type=email], input[type=tel], input[type=password] {
  padding: 0.3rem 0;
  width: 100%;
  height: 1rem;
  border: none;
  border-bottom: 1px solid #e6e6e6;
  font-size: 1rem;
  line-height: 1.3;
  color: #e6e6e6; }

.control {
  display: block;
  position: relative;
  padding-left: 30px;
  margin-bottom: 5px;
  padding-top: 5px;
  cursor: pointer; }

.control input {
  position: absolute;
  z-index: -1;
  opacity: 0; }

.control_indicator {
  position: absolute;
  top: 2px;
  left: 0;
  height: 14px;
  width: 14px;
  background: #ffffff;
  border: 1px solid #F39200; }
  .control_indicator.round {
    border-radius: 50%; }

.control:hover input ~ .control_indicator,
.control input:focus ~ .control_indicator {
  background: #cccccc; }

.control input::checked ~ .control_indicator {
  background: #ffffff; }

.control:hover input:not([disabled])::checked ~ .control_indicator,
.control input::checked:focus ~ .control_indicator {
  background: #ffffff; }

.control input::disabled ~ .control_indicator {
  background: #e6e6e6;
  opacity: 1;
  pointer-events: none; }

.control_indicator::after {
  box-sizing: unset;
  content: '';
  position: absolute;
  display: none; }

.control input:checked ~ .control_indicator:after {
  display: block; }

.control-checkbox .control_indicator:after {
  left: 4px;
  top: 0px;
  width: 3px;
  height: 8px;
  border: solid #F39200;
  border-width: 0 3px 3px 0;
  transform: rotate(45deg); }

.control-checkbox input:disabled ~ .control_indicator:after {
  border-color: #fffff; }

.control-radio .control_indicator:after {
  left: 3px;
  top: 3px;
  width: 8px;
  height: 8px;
  background-color: #F39200;
  border-radius: 50%; }

.control-radio input:disabled ~ .control_indicator:after {
  background-color: #fffff; }

/***************RESPONSIVE DESIGN***************/
@media all and (max-width: 767px) {
  .ce_form .praktikantenstellen .widget legend {
    margin: 0;
    max-width: 60%; } }
/*----------------------------
FOOTER
----------------------------*/
#footer {
  background-color: #c3c3c3; }
  #footer ul {
    display: flex;
    justify-content: space-evenly;
    color: #fff;
    line-height: 1.3em; }
  #footer a {
    color: #fff; }

/***************RESPONSIVE DESIGN***************/
@media all and (max-width: 767px) {
  #footer ul {
    flex-direction: column; } }
/*----------------------------
HEADER
----------------------------*/
#header {
  border-top: 20px solid #F39200;
  padding: 20px 0; }
  #header .inside {
    margin-top: -40px; }
  #header .wrapper {
    display: flex;
    justify-content: space-between; }
  #header .button-wrapper {
    margin-top: 20px;
    padding-top: 10px; }
    #header .button-wrapper .button {
      height: auto; }
  #header .ce_hyperlink {
    height: auto;
    width: 100%;
    box-sizing: border-box; }
  #header h2 {
    text-align: center; }

#logo {
  margin-right: 20px;
  margin-top: 30px; }

#logo-container {
  margin-left: 55px;
  display: flex;
  flex-wrap: wrap; }

#text-container {
  margin-top: 20px;
  display: flex !important;
  flex-wrap: wrap;
  height: fit-content; }

#hotline {
  text-align: center;
  color: #707070; }
  #hotline figure {
    margin-bottom: 10px; }
  #hotline p {
    border-bottom: 1px solid;
    padding-bottom: 10px; }

/***************RESPONSIVE DESIGN***************/
@media all and (max-width: 767px) {
  #header {
    padding: 20px 10px; }
    #header .wrapper {
      flex-wrap: wrap; }
    #header .ce_hyperlink {
      margin-right: 10px; }
    #header .button-wrapper {
      display: none; }

  #hotline {
    display: none !important; }

  #logo-container {
    margin-left: 0;
    flex-wrap: wrap;
    flex-basis: 33%; }

  #logo {
    max-width: 60vw;
    margin: 0 10px; }

  #text-container {
    flex-basis: 50%; } }
